Attorney Docket No. 223571 
MS # 304043.01 

PATENT APPLICATION 

Invention Title: 

DYNAMIC SESSION MAINTENANCE FOR MOBILE COMPUTING DEVICES 
Inventors: 

Pradeep Bahl US Redmond Washington 

INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 



INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 



INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 



INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 



INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 



INVENTOR'S NAME CITIZENSHIP CITY OF RESIDENCE STATE or FOREIGN COUNTRY 

Be it known that the inventors listed above have invented a certain new and useful invention 
with the title shown above of which the following is a specification. 



MS: 304043.1 
LVM: 223571 



DYNAMIC SESSION MAINTENANCE 
FOR MOBILE COMPUTING DEVICES 

FIELD OF THE INVENTION 

This invention generally relates to the area of computer systems. More 
particularly, the present invention concerns methods and systems for maintaining 
network connectivity for mobile network nodes. Mobile network nodes include, by way 
of example, portable computing devices having wireless network communication 
interfaces. Even more particularly the present invention is directed to methods and 
systems for ensuring that other nodes in a network are able to communicate with a mobile 
node even after its current assigned physical network (e.g., Internet Protocol) address 
changes. 



BACKGROUND OF THE INVENTION 

Mobile networking services facilitate connecting portable computing devices, 
generally on a temporary basis, to any of a number of networks as the portable computing 
devices are transported by users to a variety of locations. Such capabilities are typically, 
though not always, associated with wireless WAN/LAN connections. For example, a 
notebook computer may connect to a network (or subnet thereof) via any one of a number 
of wireless hotspots at geographically diverse locations. When a portable device 
connects to one of such wireless subnets, the portable device receives a unique network 
(e.g., Internet Protocol) address. One aspect of mobile computing is enabling other 
computing nodes to maintain the ability to maintain communications access to a mobile 
node notwithstanding the fact that is connected to a network using a current address that 
differs from a permanent "home" address. Thus, mechanisms have been developed to 
accommodate the substantial likelihood that at some point, the mobile node's network 
address will change, and thereafter other nodes will seek to communicate with the mobile 
node at its new network address. 

Before describing a prior known way in which networks handled mobile node 
network address changes, exemplary relevant network protocols will be briefly described. 
A number of network protocols support building temporary connections for portable 
computing devices and allocating network addresses for such computing devices. A 
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known Dynamic Host Configuration Protocol (DHCP) enables centralized, automated 
assignment of Internet Protocol addresses to machines upon connection to a network. 
DHCP enables computers to be moved to another location in a network and automatically 
receive a new Internet Protocol address corresponding to the new location. DHCP 
5 incorporates a network address "lease" functionality that assigns a variable amount of 
time that a particular assigned Internet Protocol address will be valid for a connected 
computer. The DHCP is particular useful in network environments where a limited 
number of Internet Protocol addresses are available for assignment to a large number of 
computers. 

10 A Point-to-Point Protocol (PPP) is a communications protocol for serial 

communications between two computers (e.g., a personal computer connected to a server 
via a phone line). PPP uses the Internet Protocol and provides data-link layer (layer two) 
services. In particular, PPP packages TCP/IP or other network later protocol packets and 
forwards them from a client to a server operating as the client's gateway to the Internet. 

1 5 Other protocols that are potentially relevant to mobile computing include a Point- 

to-Point Tunneling Protocol (PPTP) and Layer Two Tunneling Protocol (L2TP). The 
PPTP, an extension of PPP, facilitates extension of a network through private "tunnels" 
over public networks (e.g., the Internet). This form of interconnection is referred to as a 
Virtual Private Network (VPN) and enables a computer having PPP client support to 

20 establish a secure connection to a server via an Internet service provider. L2TP is a 
variation of PPTP. Both these tunneling protocols use a local access concentrator to 
enable packets to be tunneled over public network links thereby avoiding potentially 
needing to establish a long distance phone connection to ensure secure communications 
between a client and server. 

25 In a known networking environment, a mobile computing node is assigned a 

relatively permanent network address associated with a "home" network location. 
However, when the mobile node connects from a location outside its home network, a 
network communications server, using for example DHCP, assigns a temporary current 
address to the mobile node in support of the connection outside the home network 

30 location. During the time that the mobile node is using a temporary current address 
rather than its home address, correspondent nodes (i.e., other nodes seeking to 
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communicate with the mobile node) will use an address previously provided for the 
mobile node. Typically, unless informed of a mobile node's current, non-home address, 
correspondent nodes use the mobile node's home (permanent address) address when 
transmitting packets to the mobile node. If the mobile node is connected at a network 
5 location differing from its home location, the home address does not match the mobile 
node's current address. Such instances are accommodated, in a known network 
arrangement, by providing a home agent for the mobile node on the mobile node's home 
network. The home agent maintains the current address of the mobile node having a 
particular home network address. The home agent receives packets addressed to the 

10 mobile node's home network address, encapsulates the packets according to a tunneling 
protocol, and passes the encapsulated packets to the current address of the mobile node. 
The "from" and "to" addresses of the envelope identify the home agent and the temporary 
current point of attachment of the node respectively, while the encapsulated packets 
identify the original source and destination addresses of the received packets. 

1 5 The following illustrates the operation of a known home agent-based mobile 

networking arrangement. A mobile node having a home network address of 1 .1:1.1 is 
currently remotely connected to its home network via a temporarily assigned non-local 
address of 2.2.2.2. A correspondent node, having a network address of 7.7.7.7, is 
communicating with the mobile node using its home address of 1 . 1 . 1 . 1 . The home agent 

20 (having an address of 1 . 1 . 1 .0), aware of the mobile node's current non-local address of 
2.2.2.2, intercepts packets identifying the mobile node's home address (1.1.1.1). The 
home agent encapsulates the packets directed to the home address 1.1.1.1 according to a 
tunneling protocol. The resulting encapsulated packets specify the home agent's source 
address (1.1.1.0) and the mobile node's current address (2.2.2.2). 

25 Home agents solve a number of network address tracking problems that arise 

within a mobile node networking environment. For example, if both a correspondent 
node and a mobile node move concurrently, binding updates provided by each node to 
the last known address of the node can be lost. If the two nodes had been engaged in a 
session, the session cannot continue due to the loss of proper addresses. On the other 

30 hand, if a home agent exists for each of the two nodes, then both nodes can continue 

communications using the home addresses for the nodes. The home agents, intercept and 
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pass (tunnel) the packets identifying the home addresses to the current ( M care of) 
addresses for the mobile and correspondent nodes. 

Another potential address tracking problem that arises with regard to mobile 
nodes involves the ability of new nodes to contact the mobile node in the event that 
5 domain name system (DNS) servers, that associate names with network addresses, have 
cached the old address for a name associated with the mobile node. In such instances, the 
DNS servers, or more generally name servers, continue to provide the old/invalid address 
until the time to live (TTL) for the cached address, specified for the named mobile node, 
expires. A home agent addresses this problem by intercepting (and thereafter tunneling 

10 to the mobile node) packets containing the (home) address of the mobile node that is 
provided by the DNS servers to new nodes. The mobile node, upon receiving the 
tunneled packets, can inform the new nodes of its new address via binding updates (and 
the home agent is thereafter by-passed). 

Yet another address tracking problem involves moving a mobile node behind a 

1 5 network address translator/firewall. In this case a home agent tunnels traffic from new 
clients to the mobile node. The home agent has an open port for communication with the 
mobile node as a result of previous communications initiated by the mobile node to the 
home agent from behind the NAT/firewall. The new clients communicate indirectly with 
the mobile node (through the home agent) using the known home address of the mobile 

20 node. Home agents, while increasing the complexity of managing network 

addresses/communications, are considered valuable, if not indispensable, components 
within networking environment populated by mobile nodes. 
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SUMMARY OF THE INVENTION 

The present invention comprises a method and network administration framework 
that addresses problems described above that arise when mobile nodes are assigned new 
network addresses. In contrast to the known methods and frameworks, the present 
5 invention supports changed addresses for mobile nodes without reliance upon home 
agents. 

In particular, the present invention comprises a framework for supporting network 
address changes for a network node that is capable of attaching to a variety of networks 
and is referred to herein as a mobile node. The framework facilitates maintaining 

10 connectivity between a mobile network node and a correspondent node after the mobile 
network node changes addresses. Such connectivity is maintained by the mobile node, 
by performing the following steps. The mobile node initially registers its address with an 
authoritative name server. During registration the mobile node specifies a current 
address for the mobile node, and further specifies a value that ensures the current address 

1 5 will not be cached within non-authoritative name servers. In a particular embodiment of 
the invention, the value comprises a time-to-live value (e.g., zero) that causes non- 
authoritative name servers to discard the value, rather than caching it, after responding to 
a request that results in retrieving the mobile node's address from the authoritative name 
server. 

20 In accordance with particular exemplary embodiments of the invention, the 

mobile node performs further steps to reestablish connections to correspondent nodes. 
Such steps include registering a new mobile address with the authoritative name server 
and issuing binding updates to correspondent nodes. The mobile node also issues naming 
query requests (potentially before receiving a binding update failure) to locate a 

25 correspondent node that has also changed its address. If the naming query response 
differs from the last known address (used by the mobile node for the initial binding 
update) for the correspondent node, the mobile node issues a second binding update using 
the address provided in the naming query response. 

Furthermore in particular embodiments of the invention, in cases where the 

30 mobile node detects that it has moved to a new address that is outside a home security 

domain served by a VPN server, the mobile node establishes a tunnel connection between 
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the mobile node and the VPN server. In the case where a VPN server is unavailable, the 
mobile node initiates a binding connection through a rendezvous server residing outside 
the home network. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

While the appended claims set forth the features of the present invention with 
particularity, the invention, together with its objects and advantages, may be best 
understood from the following detailed description taken in conjunction with the 
5 accompanying drawings of which: 

FIG. 1 is a simplified schematic illustrating an exemplary architecture of a 
computing device for carrying out an embodiment of the present invention; 

FIG. 2 is an exemplary network environment wherein one or more mobile nodes 
are communicatively coupled to a home network through any one of a variety of remote 
10 network locations and receive a dynamically assigned address differing from relatively 
static home addresses assigned to the mobile nodes within the home network; 

FIG. 3 summarizes an exemplary communications stack for a networked node 
suitable for practicing the present invention; 

FIG. 4 summarizes a set of steps performed by a mobile node to connect to a non- 
1 5 home network at an address differing from a previous network address assigned to the 
mobile node; 

FIG. 5 summarizes a set of communications passed between a set of network 
nodes and their associated authoritative name servers in response to both nodes moving 
to new network locations at substantially the same time; and 
20 FIG. 6 summarizes a set of steps performed to carry out re-use of a virtual private 

node and its associated structures when a mobile node moves to a different external 
network address. 
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DETAILED DESCRIPTION OF THE DRAWINGS 

An illustrative method and framework for supporting changing addresses 
associated with mobile network nodes are disclosed herein. Such support is provided 
through enhancements to the mobile network nodes and utilizes DNS, Dynamic Host 
5 Configuration Protocol (DHCP), and Virtual Private Network (VPN) servers (or their 
functional equivalents) to dynamically assign a current network address to a mobile node, 
provide the current network address to an authoritative name server, and thereafter have 
correspondent nodes update their addresses for the mobile node based upon an address 
provided by the authoritative name server - as opposed to a cached address at a replicated 
10 name server. 

More particularly, a mobile node registers all of its name-to-address mappings 
with its authoritative DNS server using a time to live of zero. Specifying a time to live of 
zero ensures that a non-authoritative (caching/replicated) DNS server or DNS name 
resolver on a client will not store the name/address combination in its cache. Therefore, 
15 when a correspondent node loses track of a mobile node's current address, due to a 
location change by the mobile node, the correspondent node will not rely upon an old 
address stored within the non-authoritative leaf DNS server or its own name resolver 
cache. 

A second aspect of the illustrative embodiment of the invention comprises 
20 configuring mobile nodes to initiate a virtual private network connection to a virtual 
private node server for a security domain, with which the mobile node is associated, 
when the mobile node establishes a connection from outside the security domain. The 
mobile node, after initially logging onto a new network outside its home security domain 
(and receiving a new address configuration on the new network), establishes a tunneled 
25 connection into its home security domain via a VPN server within its home security 

domain. The VPN server establishes a new address for the mobile node within the home 
security domain. The new address is stored in the authoritative DNS server for the home 
security domain (with a time to live of zero). Upon registering an address failure using a 
former address for the mobile node, correspondent nodes obtain the new address 
30 provided by the authoritative DNS server to communicate with the mobile node via the 
tunneled connection supported by the VPN server. Establishing a virtual private network 
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connection is not necessary in cases where a security domain is public - i.e., the 
machines on the network are directly accessible to other machines on other networks. 

Furthermore, in the illustrative embodiment of the invention, a previously 
established VPN tunnel is re-used when a mobile node moves to a new external network 
5 address. Such capabilities are facilitated by using extension headers supported in mobile 
Internet Protocol packets and a binding update issued to a responsible VPN server to map 
a current external care of network address to a home address for the mobile node that 
forms the basis for the re-used structures maintained in accordance with the VPN tunnel. 
Thus, after initially setting up the VPN tunnel and its associated structures, the structures 
10 are maintained as the mobile node receives new external care of network addresses. 

FIG. 1 illustratively depicts an example of a suitable operating environment 100 
for a mobile computing device (e.g., a notebook or tablet computer) used in an 
environment supported by multiple, communicatively coupled networks to which the 

15 mobile computing device is capable of connecting. The operating environment 100 is 
only one example of a suitable operating environment, and is not intended to suggest any 
limitation as to the scope of use or functionality of the invention. Other well known 
computing systems, environments, and/or configurations that may be suitable for use 
with the invention include, but are not limited to, personal computers, server computers, 

20 laptop/portable/tablet computing devices, multiprocessor systems, microprocessor-based 
systems, network PCs, minicomputers, mainframe computers, distributed computing 
environments that include any of the above systems or devices, and the like. 

The invention may be described in the general context of computer-executable 
instructions, such as program modules, being executed by a computer. Generally, 

25 program modules include routines, programs, objects, components, data structures, etc. 
that perform particular tasks or implement particular abstract data types. The invention is 
potentially incorporated within network nodes operating in distributed computing 
environments where tasks are performed by remote processing devices that are linked 
through a communications network. In a distributed computing environment, program 

30 modules are generally located in local and/or remote computer storage media including 
memory storage devices. 
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With continued reference to FIG. 1, an exemplary system for implementing the 
invention includes a general purpose computing device in the form of a computer 1 10. 
Components of the computer 1 10 may include, but are not limited to, a processing unit 
120, a system memory 130, and a system bus 121 that couples various system 
5 components including the system memory to the processing unit 120. The system bus 
121 may be any of several types of bus structures including a memory bus or memory 
controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By 
way of example, and not limitation, such architectures include Industry Standard 
Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) 

10 bus, Video Electronics Standards Association (VESA) local bus, and Peripheral 
Component Interconnect (PCI) bus also known as Mezzanine bus. 

The computer 110 typically includes a variety of computer readable media. 
Computer readable media can be any available media that can be accessed by computer 
1 10 and includes both volatile and nonvolatile media, removable and non-removable 

1 5 media. By way of example, and not limitation, computer readable media may comprise 
computer storage media and communication media. Computer storage media includes 
both volatile and nonvolatile, removable and non-removable media implemented in any 
method or technology for storage of information such as computer readable instructions, 
data structures, program modules or other data. Computer storage media includes, but is 

20 not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD- 
ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, 
magnetic tape, magnetic disk storage or other magnetic storage devices, or any other 
medium which can be used to store the desired information and which can accessed by 
the computer 110. Communication media typically embodies computer readable 

25 instructions, data structures, program modules or other data in a modulated data signal 
such as a carrier wave or other transport mechanism and includes any information 
delivery media. The term "modulated data signal" means a signal that has one or more of 
its characteristics set or changed in such a manner as to encode information in the signal. 
By way of example, and not limitation, communication media includes wired media such 

30 as a wired network or direct-wired connection, and wireless media such as acoustic, RF, 
infrared and other wireless media such as wireless PAN, wireless LAN and wireless 
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WAN media. Combinations of the any of the above should also be included within the 
scope of computer readable media. 

The system memory 130 includes computer storage media in the form of volatile 
and/or nonvolatile memory such as read only memory (ROM) 131 and random access 
5 memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic 

routines that help to transfer information between elements within computer 1 1 0, such as 
during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or 
program modules that are immediately accessible to and/or presently being operated on 
by processing unit 120. By way of example, and not limitation, FIG. 1 illustrates 

10 operating system 134, application programs 135, other program modules 136, and 
program data 137. 

The computer 110 may also include other removable/non-removable, 
volatile/nonvolatile computer storage media. By way of example only, FIG. 1 illustrates 
a hard disk drive 140 that reads from or writes to non-removable, nonvolatile magnetic 

15 media, a magnetic disk drive 151 that reads from or writes to a removable, nonvolatile 
magnetic disk 152, and an optical disk drive 155 that reads from or writes to a removable, 
nonvolatile optical disk 156 such as a CD ROM or other optical media. Other 
removable/non-removable, volatile/nonvolatile computer storage media that can be used 
in the exemplary operating environment include, but are not limited to, magnetic tape 

20 cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, 
solid state ROM, and the like. The hard disk drive 141 is typically connected to the 
system bus 121 through an non-removable memory interface such as interface 140, and 
magnetic disk drive 151 and optical disk drive 155 are typically connected to the system 
bus 121 by a removable memory interface, such as interface 150. 

25 The drives and their associated computer storage media, discussed above and 

illustrated in FIG. 1, provide storage of computer readable instructions, data structures, 
program modules and other data for the computer 110. In FIG. 1, for example, hard disk 
drive 141 is illustrated as storing operating system 144, application programs 145, other 
program modules 146, and program data 147. Note that these components can either be 

30 the same as or different from operating system 134, application programs 135, other 
program modules 136, and program data 137. Operating system 144, application 
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programs 145, other program modules 146, and program data 147 are given different 
numbers here to illustrate that, at a minimum, they are different copies. A user may enter 
commands and information into the computer 20 through input devices such as a 
keyboard 162 and pointing device 161, commonly referred to as a mouse, trackball or 
5 touch pad. Other input devices (not shown) may include a microphone, joystick, game 
pad, satellite dish, scanner, or the like. These and other input devices are often 
connected to the processing unit 120 through a user input interface 160 that is coupled to 
the system bus, but may be connected by other interface and bus structures, such as a 
parallel port, game port or a universal serial bus (USB). A monitor 191 or other type of 

10 display device is also connected to the system bus 121 via an interface, such as a video 
interface 190. In addition to the monitor, computers may also include other peripheral 
output devices such as speakers 197 and printer 196, which may be connected through an 
output peripheral interface 195. 

The computer 110 may operate in a networked environment using logical 

15 connections to one or more remote computers, such as a remote computer 180. The 
remote computer 1 80 may be a personal computer, a server, a router, a network PC, a 
peer device or other common network node, and typically includes many or all of the 
elements described above relative to the computer 110, although only a memory storage 
device 181 has been illustrated in FIG. 1. The logical connections depicted in FIG. 1 

20 include a local area network (LAN) 171 and a wide area network (WAN) 1 73, but may 
also include other networks. Such networking environments are commonplace in offices, 
enterprise-wide computer networks, intranets and the Internet. 

When used in a LAN networking environment, the computer 1 10 is connected to 
the LAN 171 through one or more wired/wireless network interfaces 170. Furthermore, 

25 the set of one or more wired/wireless network interfaces 1 70 support communications 

over the WAN 173. While not shown in FIG. 1, the computer 110 potentially includes an 
internal or external modem, connected to the system bus 121 via the user input interface 
160, or other appropriate mechanism. In a networked environment, program modules 
depicted relative to the computer 1 10, or portions thereof, may be stored in the remote 

30 memory storage device. By way of example, and not limitation, FIG. 1 illustrates remote 
application programs 185 as residing on memory device 181 . It will be appreciated that 



13 

the network connections shown are exemplary and other means of establishing a 
communications link between the computers may be used. 

Before describing an exemplary network environment in which the present 
5 invention is advantageously incorporated, terminology used to describe an embodiment 
of the invention will be provided. In general, the present invention is practiced in a 
network environment including enterprise networks (e.g., networks maintained by a 
company) that are typically protected by a firewall that includes one or more virtual 
private network (VPN) servers incorporated therein. Thus, users can access the 

10 resources/entities connected to the enterprise networks by initially connecting to public 
and home networks (i.e., those within a home) and thereafter establishing a VPN tunnel 
into the enterprise networks. 

A "security domain" is a smallest domain of interconnectivity with access to/from 
the domain limited in some form of another (e.g., requiring identification/authentication 

1 5 of users via a logon process). Examples of security domains include: a home network 

protected by a firewall/NAT; an enterprise network protected by a perimeter firewall; and 
an unprotected public network such as the Internet where access is unprotected, but its 
domain breadth is delimited by perimeter firewalls established by other security domains 
to which it is connected. 

20 A "mobility domain" is a node's domain in which sessions established with the 

node remain intact as the node moves within and/or across one or more security domains. 
A mobility domain potentially spans multiple security domains. 

Turning to FIG, 2, a simple example of a network computing environment is 
25 depicted wherein the invention is potentially exploited. In the illustrative environment, a 
mobile node 200, in the form of virtually any portable computing device (e.g., a notebook 
or tablet PC, a PDA, smart phone, etc.), includes one or more network interfaces (not 
specifically shown) facilitating connectivity to a variety of networks via multiple network 
interface technologies. In the particular example depicted in FIG. 2, the mobile node 200 
30 potentially communicates through a wireless transceiver 204 (via 802. 1 1 a/b/g media 
rules/protocols) that is communicatively coupled to a local area network 206 
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corresponding to the mobile node 200's home network. The wireless transceiver 204 
(also referred to as a wireless access point, or WAP), provides access to a variety of 
resources on the LAN 206. For example, the wireless transceiver 204 provides access by 
the notebook computer 200 to directories maintained on a file server 208 and naming 
5 services supported by a DNS server 209. 

Mobile nodes 200 and 214, as their name suggests, are capable of moving to, and 
establishing a new network address, on a network differing from their home network 
(associated with Ethernet link 206). In the illustrative mobile networking environment 
set forth in FIG. 2, the mobile nodes 200 and 214 access a variety of networks/resources, 

10 including one another, while residing outside their home network, via a cellular 
transmission network including a cellular transmission tower 202. In the mobile 
networking environment illustratively depicted in FIG. 2, the mobile nodes 200 and 214 
communicate with entities connected (either directly or indirectly) to other networks, 
including the LAN 206, via the cellular transmission tower 202 that provides a first hop 

1 5 connection to a cellular network that is, in turn, connected to the Internet 212. When the 
mobile nodes 200 and 214 reside outside their home network (i.e., LAN 206), a 
gateway/firewall/modem 210, including/associated with a virtual private network (VPN) 
server, supports communications between the Internet 212 and computing devices 
connected to the LAN 206. The VPN server component enables authentication of 

20 network traffic at the perimeter of the LAN 206 by requiring outside nodes to establish a 
VPN tunnel. In the absence of a VPN server, the gate way/fire wall/modem 210 in many 
cases will accept responses to requests that are issued from an entity that resides behind 
the firewall. The gateway/firewall/modem 210 also provides access by users of the 
Internet 212 to resources on the LAN 206. 

25 Applications executing on the mobile nodes 200 and 214 potentially establish 

network connections and communicate, in a peer-to-peer arrangement, with statically 
connected client nodes 21 1 (e.g., desktop PCs), as well as other mobile nodes, via the 
wireless transceiver 204 and the cellular transmission tower 202. The DNS server 209 
supports such peer-to-peer connections by providing current addresses for named 

30 network entities. The DNS server 209 maintains, for a named network entity, a 

corresponding address(es) (i.e., address(es) on the home network of the named network 
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entity) for that name. In the case of mobile nodes, such as nodes 200 and 214, the current 
address potentially differs from the home address in cases where the mobile node is not 
currently connected to its home network. By way of example, mobile node 200 is 
assigned a home network address of 1 . 1 . 1 . 1 , and mobile node 2 14 is assigned a home 
5 address of 1 . 1 . 1 .2. When the mobile nodes 200 and 2 1 4 connect to another network, they 
receive a dynamically assigned network address differing from their assigned home 
addresses. 

The DNS server 209 provides a current address for a named network entity, 
including a mobile node, in response to naming requests submitted by network entities 

10 seeking to establish/re-establish a connection with the named entity. Furthermore, the 
name/address correlation tables utilized by DNS servers, such as DNS server 209 may be 
replicated to improve access. Of the multiple DNS servers, one such server is designated 
as "authoritative" for a given network entity. 

When a mobile node moves to a new network address, the current address 

1 5 maintained within a naming cache by a non-authoritative DNS server for a mobile node 
(e.g., mobile nodes 200 and 214) can temporarily be incorrect. The incorrect address 
remains within the naming cache until it is either replaced by an updated address, due to 
replication if existent between the DNS servers, or its time-to-live (TTL) goes to zero. 
As a consequence, when a mobile node changes addresses, an existing session with an 

20 application executing on a correspondent network node is lost/disrupted until the new 
address for the mobile node is discovered and bound to the stack. The re-discovery 
process is further complicated in instances where both nodes in a peer-to-peer connection 
are mobile nodes (e.g., nodes 200 and 214), and the mobile nodes leave their home 
network (and thereby lose access to an authoritative DNS server) at substantially the 

25 same time. 

Turning briefly to FIG. 3, an exemplary protocol stack 300 is schematically 
depicted for the mobile node 200 embodying the present invention. The illustrative 
protocol stack 300 includes, at a physical layer, a network interface card (NIC) 310 sends 
30 and receives communications via a physical interface on the mobile node 200. The NIC 
310 communicates via a network driver interface 320 (e.g., NDIS) with upper layers of 
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the protocol stack 300. One such upper layer comprises a VPN/tunnel driver 330. The 
VPN/tunnel driver 330 supports a tunnel connection between the mobile node 200 and a 
VPN server. The VPN/tunnel driver 330 packages messages in an appropriate envelope 
identifying a non-local address outside the security domain of the mobile node 200 f s 
5 home security domain. The VPN/tunnel driver 330 is by-passed when the mobile node is 
not utilizing the VPN/tunneling functionality to communicate on its home network (LAN 
206). In the illustrative embodiment depicted in FIG. 3, NDIS 320 is shown wrapping a 
portion of the tunnel driver 330 as it is used by the VPN/tunnel driver 330 to interface 
both the NIC 310 and a TCP/IP layer 340. 

10 The TCP/IP layer 340 (also including UDP driver functionality) is positioned 

above and below the VPN/tunnel driver 330 in the exemplary embodiment - reflecting 
that, in the illustrative embodiment, the VPN/tunnel driver 330 is both a client as well as 
a driver called by the TCP/IP layer 340. The TCP/IP layer 340 carries out known 
transport layer operations. The TCP/IP layer 340, in an embodiment of the invention, 

1 5 includes conditionally executed procedures such that if no acknowledgement is received 
from a relocated mobile correspondent node in response to a binding update (when the 
mobile node 200 receives a new network address), then the TCP/IP layer 340 issues a 
naming query with regard to the correspondent node to obtain a newest available network 
address available from a DNS server that the stack of the mobile node is configured to 

20 query. 

A name registration client 350, which in exemplary implementations is a part of a 
dynamic host configuration protocol (DHCP) client of the mobile node 200, includes a 
functional modification ensuring that propagation delays in getting a changed network 
address from an authoritative DNS server 209 to leaf DNS servers will not result in 

25 correspondent nodes receiving outdated information from the leaf DNS servers. In a 

particular embodiment of the invention, the name registration client 350, which operates 
to establish a network address for the mobile node 200 within the home network security 
domain, provides a current address to its authoritative DNS server 209 with a further 
directive that leaf DNS servers are not to store the name/address combination for the 

30 mobile node within their naming caches. In a particular embodiment of the invention, 
such functionality is achieved by the name registration client 350 providing a 
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name/network address update to the authoritative DNS server 209 with a time-to-live 
(TTL) of zero. Non-authoritative DNS servers will not cache an address resolution 
response from an authoritative DNS server where the response specifies a TTL of zero. 
As a consequence, all naming requests for the mobile node 200 are resolved by sole 
5 reference to the name/address resolution information maintained by the authoritative 

DNS server 209. For purposes of scalability, only a mobile node will include the TTL of 
zero functionality. Such mobility can be automated by means of detecting a startup 
whether the node is configured for mobility (e.g., on battery power and DHCP is enabled). 
The last identified component of FIG. 3 is a VPN client 360. In the illustrative 

10 embodiment of the invention, the VPN client 360 initiates establishing a VPN tunnel 
connection with a VPN server residing on a security domain differing from a security 
domain within which the mobile node 200 currently resides. In other embodiments of the 
invention, no VPN server is present on the mobile client's home network. In that case, 
the mobile node establishes a link back into the firewall protected LAN 206 via a known 

15 "rendezvous" server. The rendezvous server resides outside the LAN 206 and is 

accessible by the mobile node. The rendezvous server maintains a constant connection to 
a node inside the LAN 206 and utilizes the connection to inform a node on the other side 
of the LAN 206's firewall that mobile node 200 seeks to establish a connection with the 
node. 

20 

Turning to FIG. 4, a set of exemplary steps performed by a mobile node (for 
example mobile node 200) are summarized for re-establishing a connection to a 
correspondent node, such as mobile node 214, that is lost/disrupted due to the mobile 
node 200 changing its location from a home network address (1 . 1 . 1 . 1 ) to a network 

25 address associated with another network, such as a cellular network accessed via the 
transmission tower 202. The mobile node 200 previously provided its home address to 
its authoritative DNS server 209 with the directive that the address should not be cached 
in non-authoritative DNS servers (e.g., specifying a TTL of zero). It is further assumed 
that no home agent exists for the mobile node 200. However, a VPN server is 

30 incorporated into the gate way/fire wall/modem 210. In an illustrative example, after 
disconnecting from LAN 206 the mobile node 200, the mobile node 200 establishes a 
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VPN tunnel connection, through the gateway/firewall/modem 210 into its home network, 
LAN 206, from its new address on the cellular network. 

Initially, at step 400 the mobile node 200 receives a disconnect notification 
indicating that the mobile node 200 is no longer connected to LAN 206. Such disconnect 
5 notification can arise from any of a variety of circumstances including, by way of 
example, a user breaking a network connection between the mobile node 200 and the 
LAN 206. In response, a network communications protocol stack on the mobile node 
200 processes the disconnect notification and issues notifications to affected components 
on the mobile node 200. By way of example, upon receiving a disconnect notification a 

10 protocol stack component, or an application residing above the protocol stack, generates a 
dialog box inviting the user to establish a new connection. The dialog box, in an 
exemplary embodiment, presents a set of available networks/interfaces/modes of 
communication to the user. It is also noted that in some instances, the NDIS and TCP/IP 
stacks may not receive a disconnect notification (e.g., mobile wireless). Instead, the 

1 5 mobile node will receive a media connect notification from a new access point. 

Continuing with the current example, at step 402 the user (or possibly a criterion- 
driven automated network selection component executing upon the mobile node 200) 
selects a new network to which a connection will be established. In the illustrative 
example, the user selects the cellular network associated with the transmission tower 202. 

20 Thereafter a set of steps are performed to establish a new network connection to the 
mobile node 200's home network (LAN 206) and connect to a correspondent node 
through the new network connection. 

During step 404 the mobile node 200 connects/logs-on to the cellular wireless 
network (having a separate security domain from the LAN 206) and is dynamically 

25 assigned a new network address (e.g., 3.3.3.1) on the cellular network that differs from its 
home network address (1.1.1.1) and configuration. The DNS server for the new network 
is updated to include the new address (and name of the mobile node within the new 
security domain) of the mobile node within its name resolution table. Thus, for example, 
in the instance where the mobile node 200 disconnects from a connection to LAN 206 via 

30 wireless transceiver 204 and re-connects to the cellular network via the transmission 
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tower 202, the network address assigned to the mobile node 200 changes from the home 
address "1.1.1.1" to a remote network address of "3.33. 1." 

Thereafter, at step 406 a determination is made that the mobile node 200 now 
resides outside the security domain of the mobile node 200's home network (LAN 206). 
5 In an embodiment of the present invention, the mobile node 200 determines that it has 
moved outside the security domain of its home network (e.g., the security domain of a 
correspondent node to which a connection had previously been established) by checking 
its new network address and configuration against a policy maintained by the mobile 
node 200. For example, the policy on the mobile node 200 states that when a currently 

1 0 assigned IP address indicates a network other than 1 . 1 .x.x, the mobile node 200 should 
consider itself to be in a different security domain. The policy further specifies that its 
VPN server, to which it should connect, has an IP address of 1.1.5.0. 

At step 408 the VPN client 360 executing on the mobile node 200 initiates 
establishing a VPN tunnel connection through the VPN server executing in association 

15 with, for example, the gateway/firewall/modem 210. The VPN server connection is 
established after the mobile node 200 provides a set of logon credentials to the VPN 
server. In response to successful logon, the VPN server establishes a new address for the 
mobile node 200, by way of example 1 . 1 . 1 .5, on the LAN 206 through dynamic host 
configuration protocol (DHCP) procedures - or alternatively any of a variety of protocols 

20 such as point-to-point protocol (PPP). Thus, upon completing step 408, the VPN server 
operates as a trusted messenger for the mobile node 200 on LAN 206. As the trusted 
messenger for mobile node 200, the VPN server provides authentication, security, and 
message integrity services for the mobile node 200 on the LAN 206. 

Next, during step 410 the mobile node 200, through the VPN tunnel connection, 

25 provides its new network address (1 . 1 . 1 .5) to its authoritative DNS server 209. As 
explained previously above, in accordance with an embodiment of the invention, the 
mobile node indicates during step 410 that non-authoritative DNS servers should not 
cache the new network address (1 . 1 . 1 .5) for the mobile node. In a particular embodiment 
of the invention, this functionality is achieved by the mobile node 200 specifying a TTL 

30 of zero. As a consequence, nodes seeking to have the address of the mobile node will 
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rely solely upon the authoritative DNS server 209 to provide an address for the mobile 
node 200. 

Thereafter, at step 412 the mobile node 200, if desired, initiates re-establishing 
potentially lost connections with correspondent nodes by issuing a binding update to the 
5 last known addresses of the correspondent nodes. The binding update informs the 

correspondent nodes of the new address (1.1.1.5) assigned to the mobile node - the VPN 
server's address for the mobile node 200 upon completing step 408. If a correspondent 
node also changes its address (e.g., mobile node 214 also moves at substantially the same 
time as mobile node 200), then the binding update will fail. The mobile node 200 issues 

10 a naming query identifying the unique name assigned to the correspondent node. If the 
returned naming query address differs from an address currently held by the mobile node 
for the correspondent node, then the mobile node utilizes the provided address to issue 
another binding update. Upon receiving a binding update response, the connection 
between the mobile node and the correspondent node is restored during step 414. 

15 It is noted that as a potential optimization (especially if mobile node 200 is aware 

that the intended recipient of the binding update is also mobile), rather than wait for an 
initial binding update request to fail, the mobile node 200 executes the naming query 
before receiving a response to the initial binding update request. If the response to the 
naming query differs from the address used during the initial binding update request, then 

20 the mobile node 200 issues a further binding update request. Such optimization, though 
possibly resulting in unneeded naming queries, expedites reconnecting to a correspondent 
node that has also relocated. The optimization can be further tailored to only trigger 
based upon the relative tolerance of applications to the length of disruption of a 
connection to a correspondent node when the mobile node 200 relocates. The above- 

25 described arrangement and method for reestablishing a connection, utilizing DNS and 

VPN server components within a dynamic network environment enables a mobile node to 
reestablish connections to correspondent nodes without reliance upon a home agent when 
the mobile node moves to an address location outside its home network. 

30 Turning to FIG. 5 an exemplary set of communications/actions are depicted for a 

scenario where two mobile nodes change their locations at substantially the same time. 
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Initially, mobile nodes A and B (e.g., mobile nodes 200 and 214) are configured with 
their primary DNS suffixes. Nodes A and B also have connection-specific DNS suffixes 
for each of their adapters. The suffixes determine their current point of attachment DNS 
domains. Nodes A and B, register their addresses with their respective authoritative DNS 
5 servers 500 and 502 (which may be the same DNS server). The mobile nodes indicate 
that leaf DNS servers are not to cache their addresses by specifying a TTL of zero. A 
connection is established between Nodes A and B based upon their current addresses. 

However, at steps la, lb nodes A and B change their addresses. Next, during 
steps 2a, 2b nodes A and B acquire and register their new addresses with their 

10 authoritative DNS servers. During steps 3a, 3b the nodes A and B each issue binding 
updates to one another, but the destination of the binding update is the old address of 
each node. The binding updates therefore fail (potentially multiple times). 

During step 4a, 4b the nodes A and B each query their DNS servers 500 and 502 
to obtain the current address for their intended target. Because each specified a TTL of 

1 5 zero, the DNS servers 500 and 502 during steps 5a, 5b pass the requests to the 

authoritative DNS servers for the mobile nodes. During steps 6a, 6b the authoritative 
DNS servers 500 and 502 return the new addresses for nodes A and B. The naming 
query responses are passed back to nodes A and B during steps 7a, 7b. 

Now in possession of the most recent addresses of the moved nodes, the nodes A 

20 and B re-issue their binding updates during steps 8a, 8b and receive successful 

acknowledgements of their binding updates during steps 9a, 9b. It is noted that only one 
of the binding updates for either node A or node B need to be issued/acknowledged to re- 
establish the disrupted connection (when the two nodes moved) since the recipient of the 
binding update will get the sender's new address in the update. It is further noted that in 

25 accordance with the previously-described optimization the nodes need not wait for one or 
more binding update failures before issuing a naming query to obtain the updated 
network address for a node. 
Fast VPN tunnel re-use 

Another enhancement to the previous known systems supporting mobile nodes 

30 involves handling of VPN tunnels. In particular, in accordance with an embodiment of 
the present invention, a mobile node's VPN tunnel is quickly reset as the mobile node 
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moves from one external care of address to another external care of address. The quick 
VPN reset functionality is supported in part by an Internet security component (e.g., 
IPSEC) that resides on top of the TCP/IP layer 340 of the communications stack 
implemented by a mobile node. 
5 The mobile node 200 can automatically and quickly establish a VPN connection if 

(1) it has the address of the VPN server on LAN 206 with which it will establish a VPN 
tunnel, and (2) a network access server (and any intervening networks) between the 
mobile node 200 and the VPN server allow the mobile node 200 access to the VPN server. 
Such access is facilitated by providing the VPN server address as part of the 

10 configuration of the mobile node 200. The address can be provided in any of a variety of 
ways including manually through a configuration user interface, from a DHCP server, 
through policy downloads. Furthermore, the network to which the mobile node connects 
provides access to the Internet. An authentication server for the outside network to which 
the mobile node 200 connects is configured to support guest connections to the Internet 

15 and consequently support connection to the LAN 206' s VPN server, for nodes through a 
VLAN or VPN. Thereafter, the mobile node 200 potentially utilizes nested VPN (e.g., in 
case the guest connection is through a VPN) connections to reach a node within LAN 
206's security domain. By way of example an L2TP/IPSEC or IPSEC tunnel mode VPN 
connection is created. 

20 A performance optimization with regard to VPN connection setup enables fast 

reuse of the security data structures established for the mobile node 200 when its network 
address changes. This optimization is facilitated by the following enhancements to 
existing protocol stacks supporting network communications. First, the Internet security 
component (e.g., IPSEC) that resides on top of the TCP/IP layer 340 is called after 

25 processing the home address of the mobile node 200, and the home address, which does 
not change for the mobile node 200, is used to authenticate the mobile node for the VPN 
tunnel. The Internet SA (security association) is the context for the secure session 
between the machines. The attributes specified for an IP Security SA include, but are not 
limited to, IP addresses, authentication mechanism, cryptographic algorithm, algorithm 

30 mode, and key material. The Internet SA, which is based upon the home address, does 
not change when the mobile node 200 changes addresses. Therefore there is no need to 
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update security structures (e.g., IPSEC filters) when the mobile node 200 changes its 
address. 

Second, a previously established VPN tunnel between the mobile node 200 and a 
VPN server on the LAN 206 is reused. In an embodiment of the invention, a layer two 
5 tunneling protocol (L2TP) tunnel between the mobile node 200 and the VPN server on 
LAN 206 is maintained while the mobile node 200 moves between care of addresses 
according to mobile IPv6 rules. The mobile node 200 uses its first care of address 
external to the home security domain as its home address. It designates the first care of 
address as the home address and uses it for the tunnel and security structures to set up the 

10 VPN tunnel. Subsequently the IPSEC filters are set up with the home address. 

Turning to FIG. 6, a fast VPN tunnel re-use method supported by the above- 
described enhancements to VPN handling, when a mobile node changes its address 
multiple times in a public network, is summarized. Initially, during step 600 mobile node 
200 sets up a VPN tunnel to the VPN server (e.g., an L2TP tunnel endpoint) on LAN 206 

15 at a first external care of address. The mobile node makes the first external care of 
address its home address with regard to the external domain. 

At step 602 the mobile node 200 changes its address to a second external address. 
The mobile node 200, at step 604, sends a binding update to its VPN server/tunnel 
endpoint. The binding update maps the first address to the second address in accordance 

20 with, by way of example, IPv6. In response to the binding update, at step 606 the VPN 
server modifies its mapping (originally first to first address) to map the first address to 
the new, second address, but maintains all the original Internet protocol security 
structures (e.g., the source address - the first care of address on the external network - of 
the client establishing the VPN tunnel and other fields associated with the client at its 

25 previous address) that were previously created when the VPN tunnel was created for the 
mobile node at the first external care of address. Tunnel structures are re-used as well. 
Examples of such tunnel structures include: type of tunnel (L2TP, IPSEC), IP address of 
the client, IP address of the tunnel server, (optionally) ports at both ends (if L2TP tunnel 
protocol), kind of security being employed (such as IPSEC). In general, the present 

30 invention maintains the relevance of the previously generated tunnel structures when the 
address of the mobile client changes. This is facilitated by always using the home 
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address to look up the structure (e.g., replacing address in IP header by home address 
prior to lookup). 

Thereafter, the VPN server will attach a routing extension header, with the 
destination header option specifying the first address as the destination address, to the 
5 IPv6 header of all packets sent to the mobile node 200's new (second) address. 

At step 608, when the mobile node 200, at the second address, receives such 
packets, the IP layer replaces the second address by the first (external home) address for 
the mobile node. The modified packets are then passed up to a client of the IP layer (e.g., 
TCP, UDP, etc.). Therefore, while the mobile node 200 is indeed no longer at the first 
10 external care of address, the clients of the IP layer continue to believe that the mobile 
node 200 still resides at its first address. 

At step 610, when the mobile node 200 sends packets to the VPN server for LAN 
206, the mobile node 200 places the first address in a M home address" option of a host 
extension header attached to an IPv6 header. The second, new address of the mobile 
1 5 node is placed in the source address within the IPv6 header of a transmitted packet. 

At step 612, when the VPN server receives the transmitted packet, an IPv6 stack 
component replaces the second address in the source field by the first address before 
passing the received packet to higher layers of the communications stack. Again, the 
higher layer stack components (responsible for tunneling, verifying the authenticity of the 
20 packets passed through the tunnel and filtering unauthorized packets), such as L2TP and 
IP security filtering, are unaware of the change in address for the mobile node 200. Thus, 
the originally created tunnel and security structures for the VPN tunnel between the 
mobile node 200 and the VPN server for LAN 206 continue to work. 

In view of the many possible computing environments to which the principles of 
25 this invention may be applied and the flexibility of carrying out network access 

configuration to meet the challenges of maintaining addresses and connections in a 
networking environment including multiple mobile nodes, it should be recognized that 
the embodiment described herein is meant to be illustrative and should not be taken as 
limiting the scope of invention. Those skilled in the art to which the present invention 
30 applies will appreciate that the illustrative embodiment can be modified in arrangement 
and detail without departing from the spirit of the invention. Therefore, the invention as 
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described herein contemplates all such embodiments as may come within the scope of the 
following claims and equivalents thereof. 



